package com.mayisoftware.mayioa.business.plan.api.service;

import com.mayisoftware.mayioa.business.plan.api.domain.PlanConfig;

import java.util.List;
import java.util.Map;

/**
 * 计划配置 业务层
 *
 */
public interface IPlanConfigService
{
    /**
     * 根据条件分页查询计划配置对象
     * 
     * @param planConfig 计划配置信息
     * @return 计划配置信息集合信息
     */
    public List<PlanConfig> selectPlanConfigList(PlanConfig planConfig);

    /**
     * 通过计划名查询计划配置
     * 
     * @param planCfgName 计划名
     * @return 计划配置对象信息
     */
    public PlanConfig selectPlanConfigByName(String planCfgName);

    /**
     * 通过用户ID查询计划配置
     *
     * @param userId 用户ID
     * @return 计划配置对象信息
     */
    public List<PlanConfig> selectPlanConfigByUserId(Long userId);

    /**
     * 通过计划配置ID查询计划配置
     * 
     * @param planConfigId 计划配置ID
     * @return 计划配置对象信息
     */
    public PlanConfig selectPlanConfigById(Long planConfigId);

    /**
     * 通过计划配置ID删除计划配置
     * 
     * @param planConfigId 计划配置ID
     * @return 结果
     */
    public int deletePlanConfigById(Long planConfigId);

    /**
     * 批量删除计划配置信息
     * 
     * @param ids 需要删除的数据ID
     * @return 结果
     * @throws Exception 异常
     */
    public int deletePlanConfigByIds(String ids) throws Exception;

    /**
     * 新增计划配置信息
     * 
     * @param planConfig 计划配置信息
     * @return 结果
     */
    public int insertPlanConfig(PlanConfig planConfig);

    /**
     * 修改保存计划配置信息
     * 
     * @param planConfig 计划配置信息
     * @return 结果
     */
    public int updatePlanConfig(PlanConfig planConfig);

    /**
     * 修改保存计划配置信息
     *
     * @param planConfig 计划配置信息
     * @return 结果
     */
    public int publishPlanConfig(PlanConfig planConfig);

    /**
     * 校验计划配置名称是否唯一
     * 
     * @param planConfig 计划配置对象
     * @return 结果
     */
    public String checkPlanCfgNameUnique(PlanConfig planConfig);

    /**
     * 查询所有计划配置对象
     *
     * @return 计划配置信息集合信息
     */
    public List<PlanConfig> selectPlanConfigAll();

    /**
     * 校验计划配置是否已发布
     */
    public int checkPlanCfgIsPublish(Long planCfgId);
}
